package com.education.platform.entity;

import com.baomidou.mybatisplus.annotation.*;
import lombok.Data;
import lombok.EqualsAndHashCode;

import java.io.Serializable;
import java.time.LocalDateTime;

/**
 * 用户身份认证表
 */
@Data
@EqualsAndHashCode(callSuper = false)
@TableName("user_identity")
public class UserIdentity implements Serializable {

    private static final long serialVersionUID = 1L;

    /**
     * 主键ID
     */
    @TableId(value = "id", type = IdType.AUTO)
    private Long id;

    /**
     * 用户ID
     */
    @TableField("user_id")
    private Long userId;

    /**
     * 身份证号（加密）
     */
    @TableField("id_number_enc")
    private String idNumberEnc;

    /**
     * 身份证正面照片路径
     */
    @TableField("id_front_path")
    private String idFrontPath;

    /**
     * 身份证背面照片路径
     */
    @TableField("id_back_path")
    private String idBackPath;

    /**
     * 手持身份证照片路径
     */
    @TableField("selfie_path")
    private String selfiePath;

    /**
     * 资质证书路径列表
     */
    @TableField("certificates")
    private String certificates;

    /**
     * 审核状态
     */
    @TableField("status")
    private String status;

    /**
     * 审核备注
     */
    @TableField("audit_note")
    private String auditNote;

    /**
     * 提交时间
     */
    @TableField("submitted_at")
    private LocalDateTime submittedAt;

    /**
     * 审核时间
     */
    @TableField("audited_at")
    private LocalDateTime auditedAt;

    /**
     * 审核人ID
     */
    @TableField("audited_by")
    private Long auditedBy;

    /**
     * 创建时间
     */
    @TableField(value = "created_at", fill = FieldFill.INSERT)
    private LocalDateTime createdAt;

    /**
     * 更新时间
     */
    @TableField(value = "updated_at", fill = FieldFill.INSERT_UPDATE)
    private LocalDateTime updatedAt;
} 